<template>
  <div>
    <el-form label-width="80px" size="small" @submit.native.prevent>
      <el-form-item label="跳过表达式">
        <el-input v-model="bpmnFormData.skipExpression" @change="updateElementTask('skipExpression')" />
      </el-form-item>
      <el-form-item label="是否为补偿">
        <el-input v-model="bpmnFormData.isForCompensation" @change="updateElementTask('isForCompensation')" />
      </el-form-item>
      <el-form-item label="服务任务可触发">
        <el-input v-model="bpmnFormData.triggerable" @change="updateElementTask('triggerable')" />
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
import { StrUtil } from "@/utils/StrUtil";
export default {
  name: "OtherPanel",
  /** 组件传值  */
  props: {
    id: {
      type: String,
      required: true,
    },
  },
  data() {
    return {
      bpmnFormData: {},
    };
  },

  /** 传值监听 */
  watch: {
    id: {
      handler(newVal) {
        if (StrUtil.isNotBlank(newVal)) {
          this.resetTaskForm();
        }
      },
      immediate: true, // 立即生效
    },
  },
  created() {},
  methods: {
    // 方法区
    resetFlowForm() {
      this.bpmnFormData = JSON.parse(JSON.stringify(this.modelerStore.element.businessObject));
    },

    updateElementTask(key) {
      const taskAttr = Object.create(null);
      taskAttr[key] = this.bpmnFormData[key] || null;
      this.modelerStore.modeling.updateProperties(this.modelerStore.element, taskAttr);
    },
  },
};
</script>
<style lang="scss" scoped>
::v-deep .el-form-item__label {
  font-weight: normal;
}
</style>